package com.zhang.gmall.realtime.app.func;

import com.zhang.gmall.realtime.utils.KeywordUtil;
import org.apache.flink.table.annotation.DataTypeHint;
import org.apache.flink.table.annotation.FunctionHint;
import org.apache.flink.table.functions.TableFunction;
import org.apache.flink.types.Row;

import java.util.List;

/**
 * @title: 自定义UDTF函数
 * @author: zhang
 * @date: 2022/3/16 20:03
 * @FunctionHint 指定输出行有多少列以及每列的类型
 */
@FunctionHint(output = @DataTypeHint("ROW<word STRING>"))
public class KeywordUDTF extends TableFunction<Row> {
    public void eval(String str) {
        List<String> list = KeywordUtil.analyze(str);
        for (String word : list) {
            collect(Row.of(word));
        }
    }
}
